home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c12 / CheckCloneable.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.7 KB  |  141 lines

  1. //: CheckCloneable.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Checking to see if a handle can be cloned
  50.  
  51. // Can't clone this because it doesn't
  52. // override clone():
  53. class Ordinary {}
  54.  
  55. // Overrides clone, but doesn't implement
  56. // Cloneable:
  57. class WrongClone extends Ordinary {
  58.   public Object clone()
  59.       throws CloneNotSupportedException {
  60.     return super.clone(); // Throws exception
  61.   }
  62. }
  63.  
  64. // Does all the right things for cloning:
  65. class IsCloneable extends Ordinary 
  66.     implements Cloneable {
  67.   public Object clone() 
  68.       throws CloneNotSupportedException {
  69.     return super.clone();
  70.   }
  71. }
  72.  
  73. // Turn off cloning by throwing the exception:
  74. class NoMore extends IsCloneable {
  75.   public Object clone() 
  76.       throws CloneNotSupportedException {
  77.     throw new CloneNotSupportedException();
  78.   }
  79. }
  80.  
  81. class TryMore extends NoMore {
  82.   public Object clone() 
  83.       throws CloneNotSupportedException {
  84.     // Calls NoMore.clone(), throws exception:
  85.     return super.clone();
  86.   }
  87. }
  88.  
  89. class BackOn extends NoMore {
  90.   private BackOn duplicate(BackOn b) {
  91.     // Somehow make a copy of b
  92.     // and return that copy. This is a dummy
  93.     // copy, just to make the point:
  94.     return new BackOn();
  95.   }
  96.   public Object clone() {
  97.     // Doesn't call NoMore.clone():
  98.     return duplicate(this);
  99.   }
  100. }
  101.  
  102. // Can't inherit from this, so can't override
  103. // the clone method like in BackOn:
  104. final class ReallyNoMore extends NoMore {}
  105.  
  106. public class CheckCloneable {
  107.   static Ordinary tryToClone(Ordinary ord) {
  108.     String id = ord.getClass().getName();
  109.     Ordinary x = null;
  110.     if(ord instanceof Cloneable) {
  111.       try {
  112.         System.out.println("Attempting " + id);
  113.         x = (Ordinary)((IsCloneable)ord).clone();
  114.         System.out.println("Cloned " + id);
  115.       } catch(CloneNotSupportedException e) {
  116.         System.out.println(
  117.           "Could not clone " + id);
  118.       }
  119.     }
  120.     return x;
  121.   }
  122.   public static void main(String[] args) {
  123.     // Upcasting:
  124.     Ordinary[] ord = { 
  125.       new IsCloneable(),
  126.       new WrongClone(),
  127.       new NoMore(),
  128.       new TryMore(),
  129.       new BackOn(),
  130.       new ReallyNoMore(),
  131.     };
  132.     Ordinary x = new Ordinary();
  133.     // This won't compile, since clone() is
  134.     // protected in Object:
  135.     //! x = (Ordinary)x.clone();
  136.     // tryToClone() checks first to see if
  137.     // a class implements Cloneable:
  138.     for(int i = 0; i < ord.length; i++)
  139.       tryToClone(ord[i]);
  140.   }
  141. } ///:~